package com.cy.pj.sys.dao;

import com.cy.pj.sys.pojo.SysUser;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;

import java.util.List;

/**
 * 基于此dao对象操作用户表数据
 */
@Mapper
public interface SysUserDao {
    /**
     * 基于条件查询用户信息
     * @param sysUser 用于封装查询条件
     * @return 查询到的用户记录
     *
     */
    List <SysUser>selectUsers(SysUser sysUser);

    /**
     * 基于ID查询用户以及用户对应的部门 角色相关信息
     * @param id 用户ID
     * @return 查询到的用户信息
     */
    SysUser selectById(Integer id);

    /**
     * 修改用户状态
     * @param id 用户ID
     * @param valid 状态值
     * @param modifiedUser 修改用户
     * @return 更新的行数
     */
    @Update("update sys_users set valid=#{valid},modifiedTime=now(),modifiedUser=#{modifiedUser} where id=#{id}")
    int validById(Integer id,Integer valid,String modifiedUser);

    /**
     * 更新用户信息
      * @param sysUser
     * @return
     */
    int insertUser(SysUser sysUser);

    int updateUser(SysUser sysUser);

    /**
     * 基于用户名查找用户对象
     * @param username
     * @return
     */
    @Select("select * from sys_users where username=#{username}")
    SysUser selectUserByUsername(String username);



}





















